<template>
  <div class="flex flex-col min-h-screen">
    <div
      class="w-full md:max-w-3xl md:mx-auto px-4 mb-10 md:pb-20 md:pt-16 text-center flex-grow"
    >
      <h1 class="text-4xl font-semibold">
        Thank you!
      </h1>
      <h4 class="text-xl mt-6">
        We're checking the status of your subscription please wait a moment...
      </h4>
      <div class="text-center">
        <Loader class="h-6 w-6 text-nt-blue mx-auto mt-20" />
      </div>
    </div>
    <open-form-footer />
  </div>
</template>


<script setup>
import { useBroadcastChannel } from '@vueuse/core'

definePageMeta({
  middleware: 'auth'
})

useOpnSeoMeta({
  title: 'Subscription Success'
})

const authStore = useAuthStore()
const confetti = useConfetti()
const user = computed(() => authStore.user)
const subscribeBroadcast = useBroadcastChannel('subscribe')

const interval = ref(null)

const redirectIfSubscribed = () => {
  if (user.value.is_subscribed) {
    subscribeBroadcast.post({ 'type': 'success' })
    window.close()
  }
}
const checkSubscription = () => {
  // Fetch the user.
  return noteFormsFetch('user').then((data) => {
    authStore.setUser(data)
    redirectIfSubscribed()
  }).catch((error) => {
    console.error(error)
    clearInterval(interval.value)
  })
}

onMounted(() => {
  redirectIfSubscribed()
  interval.value = setInterval(() => checkSubscription(), 5000)
})

onBeforeUnmount(() => {
  clearInterval(interval.value)
})

onUnmounted(() => {
  // stop confettis after 2 sec
  setTimeout(() => {
    confetti.stop()
  }, 2000)
})
</script>